static GParamSpec *gtk_application_props[NUM_PROPERTIES];
-struct _GtkApplicationPrivate
+typedef struct
{
GtkApplicationImpl *impl;
GtkApplicationAccels *accels;
GtkActionMuxer *muxer;
GtkBuilder *menus_builder;
gchar *help_overlay_path;
-};
+} GtkApplicationPrivate;
G_DEFINE_TYPE_WITH_PRIVATE (GtkApplication, gtk_application, G_TYPE_APPLICATION)
GParamSpec *pspec,
GtkApplication *application)
{
- GtkApplicationPrivate *priv = application->priv;
+ GtkApplicationPrivate *priv = gtk_application_get_instance_private (application);
GList *link;
if (!gtk_window_is_active (window))
priv->windows = g_list_concat (link, priv->windows);
}
- if (application->priv->impl)
- gtk_application_impl_active_window_changed (application->priv->impl, window);
+ if (priv->impl)
+ gtk_application_impl_active_window_changed (priv->impl, window);
g_object_notify_by_pspec (G_OBJECT (application), gtk_application_props[PROP_ACTIVE_WINDOW]);
}
static void
gtk_application_load_resources (GtkApplication *application)
{
+ GtkApplicationPrivate *priv = gtk_application_get_instance_private (application);
const gchar *base_path;
base_path = g_application_get_resource_base_path (G_APPLICATION (application));
menuspath = g_strconcat (base_path, "/gtk/menus-traditional.ui", NULL);
if (g_resources_get_info (menuspath, G_RESOURCE_LOOKUP_FLAGS_NONE, NULL, NULL, NULL))
- application->priv->menus_builder = gtk_builder_new_from_resource (menuspath);
+ priv->menus_builder = gtk_builder_new_from_resource (menuspath);
g_free (menuspath);
/* If we didn't get the specific file, fall back. */
- if (application->priv->menus_builder == NULL)
+ if (priv->menus_builder == NULL)
{
menuspath = g_strconcat (base_path, "/gtk/menus.ui", NULL);
if (g_resources_get_info (menuspath, G_RESOURCE_LOOKUP_FLAGS_NONE, NULL, NULL, NULL))
- application->priv->menus_builder = gtk_builder_new_from_resource (menuspath);
+ priv->menus_builder = gtk_builder_new_from_resource (menuspath);
g_free (menuspath);
}
{
GError *error = NULL;
- if (application->priv->menus_builder == NULL)
- application->priv->menus_builder = gtk_builder_new ();
+ if (priv->menus_builder == NULL)
+ priv->menus_builder = gtk_builder_new ();
- if (!gtk_builder_add_from_resource (application->priv->menus_builder, menuspath, &error))
+ if (!gtk_builder_add_from_resource (priv->menus_builder, menuspath, &error))
g_error ("failed to load menus-common.ui: %s", error->message);
}
g_free (menuspath);
- if (application->priv->menus_builder)
+ if (priv->menus_builder)
{
GObject *menu;
- menu = gtk_builder_get_object (application->priv->menus_builder, "app-menu");
+ menu = gtk_builder_get_object (priv->menus_builder, "app-menu");
if (menu != NULL && G_IS_MENU_MODEL (menu))
gtk_application_set_app_menu (application, G_MENU_MODEL (menu));
- menu = gtk_builder_get_object (application->priv->menus_builder, "menubar");
+ menu = gtk_builder_get_object (priv->menus_builder, "menubar");
if (menu != NULL && G_IS_MENU_MODEL (menu))
gtk_application_set_menubar (application, G_MENU_MODEL (menu));
}
{
const gchar * const accels[] = { "<Primary>F1", "<Primary>question", NULL };
- application->priv->help_overlay_path = path;
+ priv->help_overlay_path = path;
gtk_application_set_accels_for_action (application, "win.show-help-overlay", accels);
}
else
gtk_application_startup (GApplication *g_application)
{
GtkApplication *application = GTK_APPLICATION (g_application);
+ GtkApplicationPrivate *priv = gtk_application_get_instance_private (application);
G_APPLICATION_CLASS (gtk_application_parent_class)->startup (g_application);
- gtk_action_muxer_insert (application->priv->muxer, "app", G_ACTION_GROUP (application));
+ gtk_action_muxer_insert (priv->muxer, "app", G_ACTION_GROUP (application));
gtk_init ();
- application->priv->impl = gtk_application_impl_new (application, gdk_display_get_default ());
- gtk_application_impl_startup (application->priv->impl, application->priv->register_session);
+ priv->impl = gtk_application_impl_new (application, gdk_display_get_default ());
+ gtk_application_impl_startup (priv->impl, priv->register_session);
gtk_application_load_resources (application);
}
gtk_application_shutdown (GApplication *g_application)
{
GtkApplication *application = GTK_APPLICATION (g_application);
+ GtkApplicationPrivate *priv = gtk_application_get_instance_private (application);
- if (application->priv->impl == NULL)
+ if (priv->impl == NULL)
return;
- gtk_application_impl_shutdown (application->priv->impl);
- g_clear_object (&application->priv->impl);
+ gtk_application_impl_shutdown (priv->impl);
+ g_clear_object (&priv->impl);
- gtk_action_muxer_remove (application->priv->muxer, "app");
+ gtk_action_muxer_remove (priv->muxer, "app");
gtk_main_sync ();
GVariant *platform_data)
{
GtkApplication *application = GTK_APPLICATION (g_application);
+ GtkApplicationPrivate *priv = gtk_application_get_instance_private (application);
- gtk_application_impl_before_emit (application->priv->impl, platform_data);
+ gtk_application_impl_before_emit (priv->impl, platform_data);
}
static void
static void
gtk_application_init (GtkApplication *application)
{
- application->priv = gtk_application_get_instance_private (application);
+ GtkApplicationPrivate *priv = gtk_application_get_instance_private (application);
- application->priv->muxer = gtk_action_muxer_new ();
+ priv = gtk_application_get_instance_private (application);
- application->priv->accels = gtk_application_accels_new ();
+ priv->muxer = gtk_action_muxer_new ();
+
+ priv->accels = gtk_application_accels_new ();
}
static void
gtk_application_window_added (GtkApplication *application,
GtkWindow *window)
{
- GtkApplicationPrivate *priv = application->priv;
+ GtkApplicationPrivate *priv = gtk_application_get_instance_private (application);
if (GTK_IS_APPLICATION_WINDOW (window))
{
gtk_application_window_removed (GtkApplication *application,
GtkWindow *window)
{
- GtkApplicationPrivate *priv = application->priv;
+ GtkApplicationPrivate *priv = gtk_application_get_instance_private (application);
gpointer old_active;
old_active = priv->windows;
GParamSpec *pspec)
{
GtkApplication *application = GTK_APPLICATION (object);
+ GtkApplicationPrivate *priv = gtk_application_get_instance_private (application);
switch (prop_id)
{
case PROP_REGISTER_SESSION:
- g_value_set_boolean (value, application->priv->register_session);
+ g_value_set_boolean (value, priv->register_session);
break;
case PROP_APP_MENU:
GParamSpec *pspec)
{
GtkApplication *application = GTK_APPLICATION (object);
+ GtkApplicationPrivate *priv = gtk_application_get_instance_private (application);
switch (prop_id)
{
case PROP_REGISTER_SESSION:
- application->priv->register_session = g_value_get_boolean (value);
+ priv->register_session = g_value_get_boolean (value);
break;
case PROP_APP_MENU:
gtk_application_finalize (GObject *object)
{
GtkApplication *application = GTK_APPLICATION (object);
+ GtkApplicationPrivate *priv = gtk_application_get_instance_private (application);
- g_clear_object (&application->priv->menus_builder);
- g_clear_object (&application->priv->app_menu);
- g_clear_object (&application->priv->menubar);
- g_clear_object (&application->priv->muxer);
- g_clear_object (&application->priv->accels);
+ g_clear_object (&priv->menus_builder);
+ g_clear_object (&priv->app_menu);
+ g_clear_object (&priv->menubar);
+ g_clear_object (&priv->muxer);
+ g_clear_object (&priv->accels);
- g_free (application->priv->help_overlay_path);
+ g_free (priv->help_overlay_path);
G_OBJECT_CLASS (gtk_application_parent_class)->finalize (object);
}
gtk_application_add_window (GtkApplication *application,
GtkWindow *window)
{
+ GtkApplicationPrivate *priv = gtk_application_get_instance_private (application);
+
g_return_if_fail (GTK_IS_APPLICATION (application));
g_return_if_fail (GTK_IS_WINDOW (window));
return;
}
- if (!g_list_find (application->priv->windows, window))
+ if (!g_list_find (priv->windows, window))
g_signal_emit (application,
gtk_application_signals[WINDOW_ADDED], 0, window);
}
gtk_application_remove_window (GtkApplication *application,
GtkWindow *window)
{
+ GtkApplicationPrivate *priv = gtk_application_get_instance_private (application);
+
g_return_if_fail (GTK_IS_APPLICATION (application));
g_return_if_fail (GTK_IS_WINDOW (window));
- if (g_list_find (application->priv->windows, window))
+ if (g_list_find (priv->windows, window))
g_signal_emit (application,
gtk_application_signals[WINDOW_REMOVED], 0, window);
}
GList *
gtk_application_get_windows (GtkApplication *application)
{
+ GtkApplicationPrivate *priv = gtk_application_get_instance_private (application);
+
g_return_val_if_fail (GTK_IS_APPLICATION (application), NULL);
- return application->priv->windows;
+ return priv->windows;
}
/**
gtk_application_get_window_by_id (GtkApplication *application,
guint id)
{
+ GtkApplicationPrivate *priv = gtk_application_get_instance_private (application);
GList *l;
g_return_val_if_fail (GTK_IS_APPLICATION (application), NULL);
- for (l = application->priv->windows; l != NULL; l = l->next)
+ for (l = priv->windows; l != NULL; l = l->next)
{
if (GTK_IS_APPLICATION_WINDOW (l->data) &&
gtk_application_window_get_id (GTK_APPLICATION_WINDOW (l->data)) == id)
GtkWindow *
gtk_application_get_active_window (GtkApplication *application)
{
+ GtkApplicationPrivate *priv = gtk_application_get_instance_private (application);
+
g_return_val_if_fail (GTK_IS_APPLICATION (application), NULL);
- return application->priv->windows ? application->priv->windows->data : NULL;
+ return priv->windows ? priv->windows->data : NULL;
}
static void
gtk_application_update_accels (GtkApplication *application)
{
+ GtkApplicationPrivate *priv = gtk_application_get_instance_private (application);
GList *l;
- for (l = application->priv->windows; l != NULL; l = l->next)
+ for (l = priv->windows; l != NULL; l = l->next)
_gtk_window_notify_keys_changed (l->data);
}
gboolean
gtk_application_prefers_app_menu (GtkApplication *application)
{
+ GtkApplicationPrivate *priv = gtk_application_get_instance_private (application);
+
g_return_val_if_fail (GTK_IS_APPLICATION (application), FALSE);
- g_return_val_if_fail (application->priv->impl != NULL, FALSE);
+ g_return_val_if_fail (priv->impl != NULL, FALSE);
- return gtk_application_impl_prefers_app_menu (application->priv->impl);
+ return gtk_application_impl_prefers_app_menu (priv->impl);
}
/**
gtk_application_set_app_menu (GtkApplication *application,
GMenuModel *app_menu)
{
+ GtkApplicationPrivate *priv = gtk_application_get_instance_private (application);
+
g_return_if_fail (GTK_IS_APPLICATION (application));
g_return_if_fail (g_application_get_is_registered (G_APPLICATION (application)));
g_return_if_fail (!g_application_get_is_remote (G_APPLICATION (application)));
g_return_if_fail (app_menu == NULL || G_IS_MENU_MODEL (app_menu));
- if (g_set_object (&application->priv->app_menu, app_menu))
+ if (g_set_object (&priv->app_menu, app_menu))
{
if (app_menu)
extract_accels_from_menu (app_menu, application);
- gtk_application_impl_set_app_menu (application->priv->impl, app_menu);
+ gtk_application_impl_set_app_menu (priv->impl, app_menu);
g_object_notify_by_pspec (G_OBJECT (application), gtk_application_props[PROP_APP_MENU]);
}
GMenuModel *
gtk_application_get_app_menu (GtkApplication *application)
{
+ GtkApplicationPrivate *priv = gtk_application_get_instance_private (application);
+
g_return_val_if_fail (GTK_IS_APPLICATION (application), NULL);
- return application->priv->app_menu;
+ return priv->app_menu;
}
/**
gtk_application_set_menubar (GtkApplication *application,
GMenuModel *menubar)
{
+ GtkApplicationPrivate *priv = gtk_application_get_instance_private (application);
+
g_return_if_fail (GTK_IS_APPLICATION (application));
g_return_if_fail (g_application_get_is_registered (G_APPLICATION (application)));
g_return_if_fail (!g_application_get_is_remote (G_APPLICATION (application)));
g_return_if_fail (menubar == NULL || G_IS_MENU_MODEL (menubar));
- if (g_set_object (&application->priv->menubar, menubar))
+ if (g_set_object (&priv->menubar, menubar))
{
if (menubar)
extract_accels_from_menu (menubar, application);
- gtk_application_impl_set_menubar (application->priv->impl, menubar);
+ gtk_application_impl_set_menubar (priv->impl, menubar);
g_object_notify_by_pspec (G_OBJECT (application), gtk_application_props[PROP_MENUBAR]);
}
GMenuModel *
gtk_application_get_menubar (GtkApplication *application)
{
+ GtkApplicationPrivate *priv = gtk_application_get_instance_private (application);
+
g_return_val_if_fail (GTK_IS_APPLICATION (application), NULL);
- return application->priv->menubar;
+ return priv->menubar;
}
/**
GtkApplicationInhibitFlags flags,
const gchar *reason)
{
+ GtkApplicationPrivate *priv = gtk_application_get_instance_private (application);
+
g_return_val_if_fail (GTK_IS_APPLICATION (application), 0);
g_return_val_if_fail (!g_application_get_is_remote (G_APPLICATION (application)), 0);
g_return_val_if_fail (window == NULL || GTK_IS_WINDOW (window), 0);
- return gtk_application_impl_inhibit (application->priv->impl, window, flags, reason);
+ return gtk_application_impl_inhibit (priv->impl, window, flags, reason);
}
/**
gtk_application_uninhibit (GtkApplication *application,
guint cookie)
{
+ GtkApplicationPrivate *priv = gtk_application_get_instance_private (application);
+
g_return_if_fail (GTK_IS_APPLICATION (application));
g_return_if_fail (!g_application_get_is_remote (G_APPLICATION (application)));
g_return_if_fail (cookie > 0);
- gtk_application_impl_uninhibit (application->priv->impl, cookie);
+ gtk_application_impl_uninhibit (priv->impl, cookie);
}
GtkActionMuxer *
gtk_application_get_parent_muxer_for_window (GtkWindow *window)
{
- GtkApplication *application;
-
- application = gtk_window_get_application (window);
+ GtkApplication *application = gtk_window_get_application (window);
+ GtkApplicationPrivate *priv = gtk_application_get_instance_private (application);
if (!application)
return NULL;
- return application->priv->muxer;
+ return priv->muxer;
}
GtkApplicationAccels *
gtk_application_get_application_accels (GtkApplication *application)
{
- return application->priv->accels;
+ GtkApplicationPrivate *priv = gtk_application_get_instance_private (application);
+
+ return priv->accels;
}
/**
gchar **
gtk_application_list_action_descriptions (GtkApplication *application)
{
+ GtkApplicationPrivate *priv = gtk_application_get_instance_private (application);
+
g_return_val_if_fail (GTK_IS_APPLICATION (application), NULL);
- return gtk_application_accels_list_action_descriptions (application->priv->accels);
+ return gtk_application_accels_list_action_descriptions (priv->accels);
}
/**
const gchar *detailed_action_name,
const gchar * const *accels)
{
+ GtkApplicationPrivate *priv = gtk_application_get_instance_private (application);
gchar *action_and_target;
g_return_if_fail (GTK_IS_APPLICATION (application));
g_return_if_fail (detailed_action_name != NULL);
g_return_if_fail (accels != NULL);
- gtk_application_accels_set_accels_for_action (application->priv->accels,
+ gtk_application_accels_set_accels_for_action (priv->accels,
detailed_action_name,
accels);
action_and_target = gtk_normalise_detailed_action_name (detailed_action_name);
- gtk_action_muxer_set_primary_accel (application->priv->muxer, action_and_target, accels[0]);
+ gtk_action_muxer_set_primary_accel (priv->muxer, action_and_target, accels[0]);
g_free (action_and_target);
gtk_application_update_accels (application);
gtk_application_get_accels_for_action (GtkApplication *application,
const gchar *detailed_action_name)
{
+ GtkApplicationPrivate *priv = gtk_application_get_instance_private (application);
+
g_return_val_if_fail (GTK_IS_APPLICATION (application), NULL);
g_return_val_if_fail (detailed_action_name != NULL, NULL);
- return gtk_application_accels_get_accels_for_action (application->priv->accels,
+ return gtk_application_accels_get_accels_for_action (priv->accels,
detailed_action_name);
}
gtk_application_get_actions_for_accel (GtkApplication *application,
const gchar *accel)
{
+ GtkApplicationPrivate *priv = gtk_application_get_instance_private (application);
+
g_return_val_if_fail (GTK_IS_APPLICATION (application), NULL);
g_return_val_if_fail (accel != NULL, NULL);
- return gtk_application_accels_get_actions_for_accel (application->priv->accels, accel);
+ return gtk_application_accels_get_actions_for_accel (priv->accels, accel);
}
GtkActionMuxer *
gtk_application_get_action_muxer (GtkApplication *application)
{
- g_assert (application->priv->muxer);
+ GtkApplicationPrivate *priv = gtk_application_get_instance_private (application);
- return application->priv->muxer;
+ g_assert (priv->muxer);
+
+ return priv->muxer;
}
void
const gchar *name,
GActionGroup *action_group)
{
- gtk_action_muxer_insert (application->priv->muxer, name, action_group);
+ GtkApplicationPrivate *priv = gtk_application_get_instance_private (application);
+
+ gtk_action_muxer_insert (priv->muxer, name, action_group);
}
void
gtk_application_handle_window_realize (GtkApplication *application,
GtkWindow *window)
{
- if (application->priv->impl)
- gtk_application_impl_handle_window_realize (application->priv->impl, window);
+ GtkApplicationPrivate *priv = gtk_application_get_instance_private (application);
+
+ if (priv->impl)
+ gtk_application_impl_handle_window_realize (priv->impl, window);
}
void
gtk_application_handle_window_map (GtkApplication *application,
GtkWindow *window)
{
- if (application->priv->impl)
- gtk_application_impl_handle_window_map (application->priv->impl, window);
+ GtkApplicationPrivate *priv = gtk_application_get_instance_private (application);
+
+ if (priv->impl)
+ gtk_application_impl_handle_window_map (priv->impl, window);
}
/**
gtk_application_get_menu_by_id (GtkApplication *application,
const gchar *id)
{
+ GtkApplicationPrivate *priv = gtk_application_get_instance_private (application);
GObject *object;
g_return_val_if_fail (GTK_IS_APPLICATION (application), NULL);
g_return_val_if_fail (id != NULL, NULL);
- if (!application->priv->menus_builder)
+ if (!priv->menus_builder)
return NULL;
- object = gtk_builder_get_object (application->priv->menus_builder, id);
+ object = gtk_builder_get_object (priv->menus_builder, id);
if (!object || !G_IS_MENU (object))
return NULL;